草庐IT

python - 计算数据结构的 md5 哈希

全部标签

ruby - ruby 哈希中的条件键/值

是否有一种很好的(单行)方式在ruby​​中编写一个散列,只有在满足条件时才会有一些条目?我想到了{:a=>'a',:b=>('b'ifcondition)}但是,如果条件不满足,那么:b==nil就会结束。我意识到这可以在两行左右轻松完成,但在一行中会更好(例如,将散列传递给函数时)。我是否(还)错过了ruby​​的另一个惊人功能?;) 最佳答案 更新Ruby2.4+自ruby​​2.4.0起,您可以使用compact方法:{a:'a',b:('b'ifcond)}.compact原始答案(Ruby1.9.2)当条件不满足时,你可

ruby-on-rails - 如何一次获取多个哈希值?

什么是这个的简短版本?:from=hash.fetch(:from)to=hash.fetch(:to)name=hash.fetch(:name)#etc注意fetch,如果键不存在,我想抛出一个错误。必须有更短的版本,例如:from,to,name=hash.fetch(:from,:to,:name)#如果需要,可以使用ActiveSupport。 最佳答案 使用哈希的values_at方法:from,to,name=hash.values_at(:from,:to,:name)这将为散列中不存在的任何键返回nil。

ruby-on-rails - Ruby rails - 从数据库中只选择几列

在rails中构建sql查询以仅从数据库中选择某些列的方法是什么,我有一些大数据字段,我想避免从连续的定期ajax调用中加载。不必要的阅读会消耗资源并且速度很慢。@itemlist=Item.find(:all,:conditions=>{....})#thisselectallcolumns我正在寻找SELECTname,addressFROMusers;而不是SELECT*FROMusers; 最佳答案 rails3:Item.select("姓名,地址").where(....)

ruby-on-rails - 在 Slim 中处理数据属性的最佳方式

我在个人项目中评估Slim作为HAML的替代品,它似乎不像HAML那样优雅地处理HTML5数据属性。我希望有人可能也遇到过这个问题,或者可能知道我尚未在他们的文档中找到的选项/语法。HAML允许您定义HTML5dataattributes只需像这样使用嵌套哈希:%a{data:{key1:'val',key2:'val'}}导致 最佳答案 Slim有多种方式作为哈希AttributeswhichwillbehyphenatedifaHashisgiven(e.g.data={a:1,b:2}willrenderasdata-a="1

ruby - 使用 RSpec 测试哈希内容

我有这样的测试:it"shouldnotindicatebackwardsjumpsifthecheckerpositionisnotaking"doboard=Board.newgame_board=board.create_test_boardboard.add_checker(game_board,:red,3,3)x_coord=3y_coord=3jump_locations={}jump_locations["upper_left"]=truejump_locations["upper_right"]=falsejump_locations["lower_left"]=fa

ruby - 如何从 Ruby 中的哈希表中获取第一个键值对

我正在尝试从ruby​​中的哈希表中获取第一个键和值键。我不知道散列的键值,因为它被传递给了方法。我在网上找不到任何地方如何找到第一个键/值作为单独的哈希表。我认为hash[0]只会尝试查找名称为0的元素,当我运行代码时它只会返回nil。我知道我可以找到键名和值,然后根据它们创建一个新的散列,但我想知道是否有更简单的方法可以做到这一点,所以我可以立即得到一个散列。这是我的代码:defrps_game_winner(game)rock_in_hash=game.invert['R']paper_in_hash=game.invert['P']scissors_in_hash=game.i

ruby - 如何转换 Ruby 哈希,使其所有键都是符号?

我有一个Ruby散列,它看起来像:{"id"=>"123","name"=>"test"}我想将其转换为:{:id=>"123",:name=>"test"} 最佳答案 hash={"apple"=>"banana","coconut"=>"domino"}Hash[hash.map{|k,v|[k.to_sym,v]}]#=>{:apple=>"banana",:coconut=>"domino"}@mu太短了:没看到“递归”这个词,但如果你坚持(以及防止不存在的to_sym,只是想提醒一下在Ruby1.81.to_sym==ni

ruby - 从哈希数组中收集值

我有以下格式的数据结构:data_hash=[{price:1,count:3},{price:2,count:3},{price:3,count:3}]有没有一种有效的方法来获取:price的值作为[1,2,3]的数组? 最佳答案 首先,如果您使用的是ruby​​array=[{:price=>1,:count=>3},{:price=>2,:count=>3},{:price=>3,:count=>3}]然后得到你需要的:array.map{|x|x[:price]} 关于ruby-

ruby - 使用哈希参数的 DRY Ruby 初始化

我发现自己在构造函数中使用了相当多的哈希参数,尤其是在为配置或最终用户将接触到的其他API位编写DSL时。我最终做的是类似下面的事情:classExamplePROPERTIES=[:name,:age]PROPERTIES.each{|p|attr_readerp}definitialize(args)PROPERTIES.eachdo|p|self.instance_variable_set"@#{p}",args[p]ifnotargs[p].nil?endendend是否没有更惯用的方法来实现这一点?一次性常量和符号到字符串的转换似乎特别令人震惊。

ruby - 在不将整个文件读入内存的情况下计算文件中的行数?

我正在处理庞大的数据文件(每个文件有数百万行)。在我开始处理之前,我想计算文件中的行数,这样我就可以指出处理的进度。由于文件的大小,将整个文件读入内存是不切实际的,只是计算有多少行。有人对如何执行此操作有好的建议吗? 最佳答案 一次一行读取文件:count=File.foreach(filename).inject(0){|c,line|c+1}或Perl-ishFile.foreach(filename){}count=$.或count=0File.open(filename){|f|count=f.read.count("\n"